
import { createApp } from 'vue'
import { createPinia } from 'pinia'

import Cookies from 'js-cookie'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import locale from 'element-plus/es/locale/lang/zh-cn'

import '@/assets/styles/index.scss' // global css

import App from './App'
import router from './router'
import directive from './directive' // directive
import './settings.css'

// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'

// 注册指令
import plugins from './plugins' // plugins

import './permission' // permission control

// 公共组件
import CommonUI from '@/components/common'
import BwtonUI from '@/components/BwtonUI'

const app = createApp(App)

app.use(createPinia())
app.use(router)
app.use(plugins)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)

app.use(CommonUI)
app.use(BwtonUI)

directive(app)

// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
    locale: locale,
    // 支持 large、default、small
    size: Cookies.get('size') || 'default'
  })

app.mount('#app')
